package com.ctsi.ssdc.service;

import com.ctsi.ssdc.entity.Excel08VO.Excel15VO;
import com.ctsi.ssdc.entity.Excel15;
import com.ctsi.ssdc.entity.TradeAndServiceIndustry;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;

import java.util.Date;
import java.util.List;
import java.util.concurrent.Future;

/**
 * 15基础表贸易分行业(Excel15)表服务接口
 *
 * @author makejava
 * @since 2023-02-21 16:26:43
 */
public interface Excel15Service {

    /**
     * 通过ID查询单条数据
     *
     * @param id 主键
     * @return 实例对象
     */
    Excel15 queryById(Long id);

    /**
     * 分页查询
     *
     * @param excel15     筛选条件
     * @param pageRequest 分页对象
     * @return 查询结果
     */
    Page<Excel15> queryByPage(Excel15 excel15, Pageable pageRequest);

    /**
     * 新增数据
     *
     * @param excel15 实例对象
     * @return 实例对象
     */
    Excel15 insert(Excel15 excel15);

    /**
     * 修改数据
     *
     * @param excel15 实例对象
     * @return 实例对象
     */
    Excel15 update(Excel15 excel15);

    /**
     * 通过主键删除数据
     *
     * @param id 主键
     * @return 是否成功
     */
    boolean deleteById(Long id);

    /**
     * 批量增加
     * @param list
     * @return
     */
    boolean insertBatch(List<Excel15> list);

    List<Excel15VO> keyInfo(String year, String month);

    TradeAndServiceIndustry getTurnoverTotal(String year, String month);

    TradeAndServiceIndustry getWholesaleTurnoverTotal(String year, String month);

    TradeAndServiceIndustry getRetailTurnoverTotal(String year, String month);

    TradeAndServiceIndustry getLodgingTurnoverTotal(String year, String month);

    TradeAndServiceIndustry getCateringTurnoverTotal(String year, String month);

    /**
     * 根据日期删除
     * @param date
     * @return 是否成功
     */
    boolean removeByDate(Date date);
}
